package com.ymk.service.impl;

import com.alibaba.dubbo.config.annotation.Service;
import com.sun.org.apache.bcel.internal.generic.FALOAD;
import com.ymk.constant.MessageConstant;
import com.ymk.dao.MemberDao;
import com.ymk.dao.OrderDao;
import com.ymk.dao.OrderSettingDao;
import com.ymk.pojo.Member;
import com.ymk.pojo.Order;
import com.ymk.pojo.OrderSetting;
import com.ymk.service.OrderService;
import com.ymk.util.DateUtils;
import com.ymk.vo.Result;
import org.aspectj.weaver.ast.Or;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.transaction.annotation.Transactional;

import java.util.Date;
import java.util.List;
import java.util.Map;

@Service(interfaceClass = OrderService.class)
@Transactional
public class OrderServiceImpl implements OrderService {

    @Autowired
    private OrderSettingDao orderSettingDao;

    @Autowired
    private MemberDao memberDao;

    @Autowired
    private OrderDao orderDao;

    //旅游预约
    @Override
    public Result order(Map map) throws Exception {
        //检查当前日期是否进行了预约设置
        String orderDate = (String) map.get("orderDate");
        //因为数据库预约设置表里面的时间时date类型，http协议传递的时字符串类型，
        //所以需要转换
        Date date = DateUtils.parseString2Date(orderDate);
        //使用预约时间查询预约设置表，看看是否可以进行预约
        //（1）使用预约时间，查询预约设置表，判断是否有该记录
        OrderSetting orderSetting = orderSettingDao.findByOrderDate(date);
        //如果有预约设置表等于null,说明不能进行预约，压根就没有开团
        if(orderSetting == null) {
            return new Result(false, MessageConstant.SELECTED_DATE_CANNOT_ORDER);
        }else{
            //如果有，说明可以进行预约，//可预约人数
            int number = orderSetting.getNumber();
            //已预约人数
            int reservations = orderSetting.getReservations();
            //如果预约人数大于等于最大预约数，此时不能预约，提示“预约已满”
            if(reservations >= number){
                return new Result(false,MessageConstant.ORDER_FULL);
            }
        }

        //获取手机号
        String telephone = (String) map.get("telephone");
        //(2).根据手机号，查询会员表，判断当前预约人是否是会员
        //根据手机号，查询会员表，判断当前预约人是否时会员
        Member member = memberDao.findByTelephone(telephone);
        //如果是会员，防止重复预约（一个会员，一个时间，一个套餐不能重复，否则是重复预约）
        if(member != null){
            Integer memberId = member.getId();
            //获取套餐id
            int setmealId = Integer.parseInt((String) map.get("setmealId"));
            Order order = new Order(memberId,date,null,null,setmealId);
            //根据预约信息查询是否已经预约
            List<Order> list = orderDao.findByCondition(order);
            //判断是否已经预约，list不等于null,说明已经预约，不能重复预约
            if(list != null && list.size() > 0){
                //已经完成了预约，不能重复预约
                return new Result(false,MessageConstant.HAS_ORDERED);
            }
        }else{
            //如果不是会员：注册会员，向会员表中添加数据
            member = new Member();
            member.setName((String)map.get("name"));
            member.setSex((String)map.get("sex"));
            member.setPhoneNumber((String)map.get("telephone"));
            member.setIdCard((String)map.get("idCard"));
            member.setRegTime(new Date());//会员注册时间，当前时间
            memberDao.add(member);
        }
        //(3)可以进行预约，更新预约设置表中预约人数的值，使其的值+1
        //可以预约，设置预约的人数加1
        orderSetting.setReservations(orderSetting.getReservations()+1);
        orderSettingDao.editReservationsByOrderDate(orderSetting);

        //(4)可以进行预约，向预约表中添加1条数据
        //保存预约信息到预约表
        Order order = new Order();
        order.setMemberId(member.getId());//会员ID
        order.setOrderDate(date);//预约时间
        order.setOrderStatus(Order.ORDERSTATUS_NO);//预约状态（已出游/未出游）
        order.setOrderType((String)map.get("orderType"));
        order.setSetmealId(Integer.parseInt((String)map.get("setmealId")));
        orderDao.add(order);
        return new Result(true,MessageConstant.ORDER_SUCCESS,order);
    }

    @Override
    public Map findById4Detail(Integer id) throws Exception {
        Map map = orderDao.findById4Deatail(id);
        if(map != null){
            //处理日期格式
            Date orderDate = (Date)map.get("orderDate");
            map.put("orderDate",DateUtils.parseDate2String(orderDate));
            return map;
        }
        return map;
    }
}
